# **EEE 3101: Digital Logic and Circuits**

# Multiplexer & De-Multiplexer

# **Course Teacher: Nafiz Ahmed Chisty**

Associate Professor, Department of EEE & CoE
Head (UG), Department of EEE
Faculty of Engineering
Room# DNG03, Ground Floor, D Building
Email: chisty@aiub.edu

Website: http://engg.aiub.edu/ Website: www.nachisty.com





### Multiplexer or Mux or Data Selector

In the old days, several machines could share an I/O device with a Switch. The Switch allows one computer's output to go to the printer's input.



Multiplexer (or mux), also known as a data selector, is a device that selects between several input signals and forwards the selected input to a single output line. A multiplexer of 2<sup>n</sup> inputs has n select lines, which are used to select which input line to send to the output.

Data (2<sup>n</sup> numbers) 

Select (n numbers)

- This is a 2-to-1 multiplexer or mux.
- The multiplexer routes one of its data inputs (D0 or D1) to the output Q, based on the value of S:
  - If S=0, then D0 is the output (Q=D0).
  - If S=1, then D1 is the output (Q=D1).









## **Block diagram, Truth table and Circuit**

Block Diagram:



Truth table:

|   |    |    |   | _ |   |    |
|---|----|----|---|---|---|----|
| 5 | D1 | DO | Q |   |   |    |
| 0 | 0  | 0  | 0 |   |   |    |
| 0 | 0  | 1  | 1 |   |   |    |
| 0 | 1  | 0  | 0 |   | 5 | Q  |
| 0 | 1  | 1  | 1 |   |   |    |
| 1 | 0  | 0  | 0 |   | 0 | D0 |
| 1 | •  | 1  | 0 |   | 1 | D1 |
| 7 | 0  | 1  | U | ' | • |    |
| 1 | 1  | 0  | 1 |   |   |    |
| 1 | 1  | 1  | 1 |   |   |    |

Circuit Diagram:



Q = S' DO + S D1

When S=0

$$Q = 0' D0 + 0 D1$$

$$Q = 1 D0 + 0$$

Q = D0

When S=1

$$Q = 0 D0 + 1 D1$$

Q = D1

$$Q = S' DO + S D1$$





# **4x1 Multiplexer**

#### Block Diagram:



#### Circuit Diagram:



#### Truth table:

| Select | Output<br>(selected<br>input) |       |
|--------|-------------------------------|-------|
| $S_1$  | $S_0$                         | Q     |
| 0      | 0                             | $D_0$ |
| 0      | 1                             | $D_1$ |
| 1      | 0                             | $D_2$ |
| 1      | 1                             | $D_3$ |







#### **Timing Diagram**



| Select | Output<br>(selected<br>input) |         |
|--------|-------------------------------|---------|
| $S_1$  | $S_0$                         | Q       |
| 0      | 0                             | $D_0$   |
| 0      | 1                             | $D_{1}$ |
| 1      | 0                             | $D_2$   |
| 1      | 1                             | $D_3$   |



ΕN

S

D1





## Enable inputs



- Many devices have an additional enable input, which "activates" or "deactivates" the device.
- We could design a 2-to-1 multiplexer with an enable input that's used as follows.
  - EN=0 disables the multiplexer, which forces the output to be 0. (It does not turn off the multiplexer.)
  - EN=1 enables the multiplexer, and it works as specified earlier.
- Enable inputs are especially useful in combining smaller muxes together to make larger ones, as we'll see later today.

|   | _ |   | - | 4 |  |
|---|---|---|---|---|--|
| 0 | 0 | 0 | 0 | 0 |  |
| 0 | 0 | 0 | 1 | 0 |  |
| 0 | 0 | 1 | 0 | 0 |  |
| 0 | 0 | 1 | 1 | 0 |  |
| 0 | 1 | 0 | 0 | 0 |  |
| 0 | 1 | 0 | 1 | 0 |  |
| 0 | 1 | 1 | 0 | 0 |  |
| 0 | 1 | 1 | 1 | 0 |  |
| 1 | 0 | 0 | 0 | 0 |  |
| 1 | 0 | 0 | 1 | 1 |  |
| 1 | 0 | 1 | 0 | 0 |  |
| 1 | 0 | 1 | 1 | 1 |  |
| 1 | 1 | 0 | 0 | 0 |  |
| 1 | 1 | 0 | 1 | 0 |  |
| 1 | 4 | 1 | 0 | 1 |  |

D0

| EN | S | D1 | D0 | Q |
|----|---|----|----|---|
| 0  | Х | X  | X  | 0 |
| 1  | 0 | 0  | 0  | 0 |
| 1  | 0 | 0  | 1  | 1 |
| 1  | 0 | 1  | 0  | 0 |
| 1  | 0 | 1  | 1  | 1 |
| 1  | 1 | 0  | 0  | 0 |
| 1  | 1 | 0  | 1  | 0 |
| 1  | 1 | 1  | 0  | 1 |
| 1  | 1 | 1  | 1  | 1 |

| EN | S | Q  |
|----|---|----|
| 0  | X | 0  |
| 1  | 0 | DO |
| 1  | 1 | D1 |

Output







#### Implementation of Higher-order Multiplexers using lower-order Multiplexers

#### 8x1 Mux using ONLY 4x1 Mux

| Sel            | ect In <sub>l</sub> | Output<br>(selecte<br>d input) |                |
|----------------|---------------------|--------------------------------|----------------|
| S <sub>2</sub> | S <sub>1</sub>      | $S_0$                          | Q              |
| 0              | 0                   | 0                              | $D_0$          |
| 0              | 0                   | 1                              | $D_1$          |
| 0              | 1                   | 0                              | $D_2$          |
| 0              | 1                   | 1                              | $D_3$          |
| 1              | 0                   | 0                              | $D_4$          |
| 1              | 0                   | 1                              | D <sub>5</sub> |
| 1              | 1                   | 0                              | $D_6$          |
| 1              | 1                   | 1                              | D <sub>7</sub> |









## **Implementing functions with multiplexers**

- Muxes can be used to implement arbitrary functions.
- One way to implement a function of *n* variables is to use an 2<sup>n</sup>-to-1 mux:
- For example, let's look at  $f(x,y,z) = \Sigma(1,2,6,7)$ .

| × | У | Z | f   |             |
|---|---|---|-----|-------------|
| 0 | 0 | 0 | 0 - | <b>→</b> D0 |
| 0 | 0 | 1 | 1 - | <b>→</b> D1 |
| 0 | 1 | 0 | 1 - | <b>→</b> D2 |
| 0 | 1 | 1 | 0 - | <b>D</b> 3  |
| 1 | 0 | 0 | 0 - | <b>→</b> D4 |
| 1 | 0 | 1 | 0 - | <b>→</b> D5 |
| 1 | 1 | 0 | 1   | <b>D</b> 6  |
| 1 | 1 | 1 | 1 - | <b>→</b> D7 |

| Sel            | ect In | Output<br>(selecte<br>d input) |                |
|----------------|--------|--------------------------------|----------------|
| S <sub>2</sub> | $S_1$  | $S_0$                          | Q              |
| 0              | 0      | 0                              | $D_0$          |
| 0              | 0      | 1                              | $D_1$          |
| 0              | 1      | 0                              | $D_2$          |
| 0              | 1      | 1                              | $D_3$          |
| 1              | 0      | 0                              | $D_4$          |
| 1              | 0      | 1                              | $D_5$          |
| 1              | 1      | 0                              | $D_6$          |
| 1              | 1      | 1                              | D <sub>7</sub> |









#### **MULTIPLEXER**

**Boolean Function Implementation (advanced)** 

Question: Implement the following function with only one 4-to-1 multiplexer:

$$F(A,B,C)=\Sigma(1,3,5,6)$$

For **3 variables**, it takes:

- a) One 8-to-1 Mux, or
- Three 4-to-1 Mux

# Only ONE 4-to-1 ..???





#### **Procedure**:

Implement the truth table and write the SOP expression in the decimal format:

| Minterms | A | В | С | F |
|----------|---|---|---|---|
| 0        | 0 | 0 | 0 | 0 |
| 1        | 0 | 0 | 1 | 1 |
| 2        | 0 | 1 | 0 | 0 |
| 3        | 0 | 1 | 1 | 1 |
| 4        | 1 | 0 | 0 | 0 |
| 5        | 1 | 0 | 1 | 1 |
| 6        | 1 | 1 | 0 | 1 |
| 7        | 1 | 1 | 1 | 0 |

$$F(A,B,C) = \Sigma (1, 3, 5, 6)$$

If the Boolean function has n+1 Variables, then connect n
of these variables to the select lines of a MUX maintain the
order.

$$n+1=3$$
$$\Rightarrow n=2$$

 Based on the select lines, find the total number of input lines for the MUX. The remaining variable will be used for the inputs of the MUX.







- Consider now the single variable **A**. It can either be **0 or 1**.
- From the truth table, find the minterms for which **A** is **0**. The minterms are 0, 1, 2 & 3.
- From the truth table, find the minterms for which **A** is **1**. The minterms are 4, 5, 6 & 7.

| N | /linterms | A | В | С | F |
|---|-----------|---|---|---|---|
|   | 0         | 0 | 0 | 0 | 0 |
|   | 1         | 0 | 0 | 1 | 1 |
|   | 2         | 0 | 1 | 0 | 0 |
|   | 3         | 0 | 1 | 1 | 1 |
|   | 4         | 1 | 0 | 0 | 0 |
|   | 5         | 1 | 0 | 1 | 1 |
|   | 6         | 1 | 1 | 0 | 1 |
|   | 7         | 1 | 1 | 1 | 0 |

|    | l <sub>o</sub> | l <sub>1</sub> | l <sub>2</sub> | l <sub>3</sub> |
|----|----------------|----------------|----------------|----------------|
| A' | 0              | 1              | 2              | 3              |
| Α  | 4              | 5              | 6              | 7              |
|    |                |                |                |                |

- List the inputs of the MUX and under them list all the minterms in two rows.
- The first row lists all those minterms where **A** is **0**, and the second row all the minterms with **A** is **1**.





**Circle** all the minterms of the function and inspect **each column** separately.

$$F(A,B,C) = \Sigma (1, 3, 5, 6)$$

|    | I <sub>o</sub> | l <sub>1</sub> | <b>l</b> <sub>2</sub> | l <sub>3</sub> |
|----|----------------|----------------|-----------------------|----------------|
| A' | 0              | 1              | 2                     | 3              |
| Α  | 4              | 5              | 6                     | 7              |
|    | 0              | 1              | Α                     | A'             |

- If the two minterms in a column are not circled, apply 0 to the corresponding MUX input.
- If the two minterms are circled, apply 1 to the corresponding MUX input.
- If the bottom minterm is circled and the top is not circled, apply A (for this example) to the corresponding MUX input.
- If the top minterm is circled and the bottom is not circled, apply A' (for this example) to the corresponding MUX input.







# $F(A,B,C)=\Sigma(1,3,5,6)$

| Minterms | A | В | С | F |
|----------|---|---|---|---|
| 0        | 0 | 0 | 0 | 0 |
| 1        | 0 | 0 | 1 | 1 |
| 2        | 0 | 1 | 0 | 0 |
| 3        | 0 | 1 | 1 | 1 |
| 4        | 1 | 0 | 0 | 0 |
| 5        | 1 | 0 | 1 | 1 |
| 6        | 1 | 1 | 0 | 1 |
| 7        | 1 | 1 | 1 | 0 |

|    | I <sub>o</sub> | l <sub>1</sub> | <b>I</b> <sub>2</sub> | l <sub>3</sub> |
|----|----------------|----------------|-----------------------|----------------|
| Α' | 0              | 1              | 2                     | 3              |
| Α  | 4              | 5              | 6                     | 7              |
|    | 0              | 4              | Α                     | Α'             |







#### **Example:** Implement the following function using 4x1 MUX:

$$F(A,B,C) = \Sigma (2, 3, 4, 6)$$

| Minter<br>ms | Α | В | С | F |
|--------------|---|---|---|---|
| 0            | 0 | 0 | 0 | 0 |
| 1            | 0 | 0 | 1 | 0 |
| 2            | 0 | 1 | 0 | 1 |
| 3            | 0 | 1 | 1 | 1 |
| 4            | 1 | 0 | 0 | 1 |
| 5            | 1 | 0 | 1 | 0 |
| 6            | 1 | 1 | 0 | 1 |
| 7            | 1 | 1 | 1 | 0 |
|              |   |   |   |   |

|     | ۱. |                |                        |                |   | Α  | - |
|-----|----|----------------|------------------------|----------------|---|----|---|
|     | 0  | l <sub>1</sub> | I <sub>2</sub>         | I <sub>3</sub> | - | 0  | - |
| _A' | 0  | 1              | (2) (                  | 3)             | _ | 1  | - |
| Α   | 4  | 5              | l <sub>2</sub> (2) (6) | 7              | _ | A' | - |
|     | Α  | 0              | 1                      | A'             |   |    |   |

|    | l <sub>o</sub> | l <sub>1</sub> | l <sub>2</sub> | l <sub>3</sub> |
|----|----------------|----------------|----------------|----------------|
| B' | 0              | 1              | 4              | 5              |
| В  | (2)            | (3)            | <b>6</b>       | 7              |
|    | В              | В              | 1              | 0              |

|    | l <sub>o</sub> | l <sub>1</sub> | l <sub>2</sub> | l <sub>3</sub> |
|----|----------------|----------------|----------------|----------------|
| C' | 0              | 2              | 4              | 6              |
| С  | 1              | (3)            | 5              | 7              |
|    | 0              | 1              | C'             | C'             |



4X1

Υ









$$F(A,B,C) = AB+BC$$

$$F (A,B,C) = AB+BC$$

$$= AB(C+C')+(A+A')BC$$

$$= ABC+ABC'+ABC+A'BC$$

$$= ABC+ABC' +A'BC$$

$$7 6 3$$

$$F(A,B,C) = \Sigma (3,6,7)$$

|    | l <sub>o</sub> | l <sub>1</sub> | l <sub>2</sub> | l <sub>3</sub> |
|----|----------------|----------------|----------------|----------------|
| Α' | 0              | 1              | 2              | 3              |
| Α  | 4              | 5              | 6              | 7              |
|    | 0              | 0              | Α              | 1              |

| Minterm | A | В | С | F |
|---------|---|---|---|---|
| 0       | 0 | 0 | 0 | 0 |
| 1       | 0 | 0 | 1 | 0 |
| 2       | 0 | 1 | 0 | 0 |
| 3       | 0 | 1 | 1 | 1 |
| 4       | 1 | 0 | 0 | 0 |
| 5       | 1 | 0 | 1 | 0 |
| 6       | 1 | 1 | 0 | 1 |
| 7       | 1 | 1 | 1 | 1 |



 $D_0$ 

 $D_1$  $D_2$ 

 $D_3$ 

Data output

lines





## **Demultiplexers**

#### 1-line-to 4-line demux

A demultiplexer (DEMUX) basically reverses the multiplexing function. It takes digital information from one line and distributes it to a given number of output lines. For this reason, the demultiplexer is also known as a data distributor. As you will learn, decoders can also be used as demultiplexers.







#### **Timing Diagram**



|   | 1x4         | D <sub>o</sub> |
|---|-------------|----------------|
| _ | $S_1$ $S_0$ |                |
|   |             |                |

| DATA-SELE      | CT INPUTS |                 |
|----------------|-----------|-----------------|
| S <sub>1</sub> | So        | OUTPUT SELECTED |
| 0              | 0         | $D_0$           |
| 0              | 1         | $D_1$           |
| 1              | 0         | $D_2$           |
| 1              | 1         | $D_3$           |











## **Reference:**

- [1] Thomas L. Floyd, "Digital Fundamentals" 11th edition, Prentice Hall.
- [2] M. Morris Mano, "Digital Logic & Computer Design" Prentice Hall.
- [3] Mixed contents from Vahid And Howard.

